MULTI-TASKING

Section: Miscellaneous Library Functions (3X)
Updated: August 1, 1990
Index Return to Main Contents
 

NAME

multi-tasking - tile forth kernel extensions for concurrent programming  

SYNOPSIS

#include multi-tasking.f83

multi-tasking  

DESCRIPTION

The tile kernel and forth level extensions to allow concurrent programming with tasks, condition variables, semaphores, channels and rendezvous. The tasking switch mechanism in the tile kernel is not time-multiplexed and applications are required to periodically call the task switch function, "detach", or, "resume", or synchronization functions such as semaphores, condition variables, etc. This extension implement the major concurrent programming concepts and allows programming for a common memory or distributed model.
: .task ( task -- )
Displays the internal state of a task. The state is not the state of the running task as this word will display the memory structure of a task, and not the virtual machine state. A task cannot display its own state.
constant >terminate ( -- addr)
Constant containing a pointer to the terminate function. Used by "task" to automatically terminate task which arrive at the end of their task body, i.e., forth-level code section.
: ?avail ( chan -- bool)
Check whether a channel "receive" operation will not block. Data is available directly. Returns "true" if data is directly available without waiting else "false".
: ?awaiting ( -- bool) immediate
Used in the following form:
?awaiting <rendezvous-name> ( -- bool)
in a server task to check if a client task is waiting for service. Returns "true" if a client task is waiting else "false".
: ?wait ( semaphore -- bool)
Checks the semaphore counter to determine if a "wait" operation will make a task wait. Returns "true" in this case otherwise "false".
enum.type COMMUNICATION-MODELS ( -- )
Enumerate type used to select the operation type of a channel. The models are; "ONE-TO-ONE", "ONE-TO-MANY", and "MANY-TO-ONE".
struct.type CHAN ( model -- )
Used in the following form to create a channel:
<communication-model> CHAN <chan-name> ( -- chan)
The channel is represented by two synchronization semaphores and a common data area. May be used for three major communication styles between tasks. These are defined by the enumeration type "COMMUNICATION-MODES". The operations on a channel are "send", "receive" and "?avail".
struct.type CONDITION ( -- )
Used as in the following form:
CONDITION <condition-name> ( -- condition)
to create and initiate a named condition queue variable. The possible operations, other than queue operations, on a condition queue are "await" and "cause".
enum DELAYED ( -- enum)
Task status code for task performing "delay". Will resume "RUNNING" after the "delay" operation.
enum IOWAITING ( -- enum)
Task status code for task waiting for IO. The foreground task is currently the only task allowed to perform io-operations, input, as these are not reentrant.
enum MANY-TO-ONE ( -- enum)
Selects the many-to-one communication mode of a channel. Several sending tasks are allowed to communicate with a service task.
enum ONE-TO-ONE ( -- enum)
The channel is to be operated in a one-to-one manner.
enum ONE-TO-MANY ( -- enum)
The channel is to be operated in a one-to-many manner. Several receiving tasks are possible on the channel. Data sent on the channel is maintained from corruption.
enum READY ( -- enum)
Task status code for newly created tasks, ready for scheduling.
struct.type RENDEZVOUS ( -- )
Used in the following form:
RENDEZVOUS <rendezvous-name> ( arg -- res)
to create a rendezvous name. This name may then be used as a function service by some task with "accept".
<rendezvous-name> ( arg -- res)
The function always takes one argument and always returns one result value. The service block is terminated by the word "accept.end".
enum RUNNING ( -- enum)
Task status code for running, scheduled, tasks.
struct.type SEMAPHORE ( value -- )
Used in the following form:
<value> SEMAPHORE <semaphore-name> ( -- semaphore)
to create and initiate a named semaphore. The possible operations on a semaphore are "?wait", "wait", and "signal".
struct.type TASK-HEADER ( -- )
Definition of the instance structure of a task header. Defines the field names for a task; "+queue", "+sp", "+s0", "+rp", "+r0", "+fp", and "+ep".
enum.type TASK-STATUS-CODES ( -- )
Enumerate defining the possible task status codes. The codes are; "READY", "DELAYED", "RUNNING", "WAITING", "IOWAITING", and "TERMINATED".
enum TERMINATED ( -- enum)
Task status code for terminated tasks.
enum WAITING ( -- enum)
Task status code for task performing a generic wait operation.
: accept ( -- arg) immediate
Using in the following form:
accept <rendezvous-name> ( arg -- res)
... <service-definition> ...
accept.end
to accept calls on the rendezvous. When a client task calls the rendezvous the argument from client is passed to the server task that performed the accept.
: accept.end ( res -- ) immediate
Marks the end of an accept block in a server task. The result is passed to the client task and both may continue in parallel.
: activate ( task -- )
Inserts a task first in the queue of runnable task and resumed. The task is assumed to have be scheduled and deactivated. The task is now marked as "RUNNING".
: await ( condition -- )
Causes the running task to wait for a condition. The task is deactivated and places in the queue associated with the condition. The task status is "WAITING" while in the queue.
task.field byte ( -- )
Used in the following form:
byte <user-name> ( -- addr)
within a task type definitions. Creates a user variable access name to a byte.
: bytes ( size -- )
Used in the following form to create named local structures and data within task instances:
<number> bytes <user-field-name> ( -- addr)
Should only be used within the layout section of a task type.
: cause ( condition -- )
Activates the first waiting task in the condition queue. The task status will become "RUNNING".
: deactivate ( queue task -- )
Removes a task from the queue of runnable task and inserts it into the given queue. The task is marked as "WAITING". The next runnable task is resumed.
: delay ( n -- )
Delays a task a number of task switches. The delay is not real-time but relative time. The task status is "DELAYED" during the delay.
code detach ( -- )
Deactivate the current running task and resumes the next task in the queue over runnable tasks.
task.field enum ( -- )
Used in the following form:
enum <user-name> ( -- addr)
within a task type definitions. Creates a user variable access name to an enumerative, four bytes counter.
variable foreground ( -- addr)
Variable containing a pointer to the foreground task.
code fork ( -- task)
Copies the current task and returns a pointer to it. The child task will receive a pointer to the parent task as result of fork. The parent will receive a pointer to the child task. The child is scheduled directly.
: join ( task -- )
Delay a task until the task given as parameter terminates. The task status is "WAITING" during the join delay.
task.field long ( -- )
Used in the following form:
long <user-name> ( -- addr)
within a task type definitions. Creates a user variable access name to a long, four bytes.
task.field ptr ( -- )
Used in the following form:
ptr <user-name> ( -- addr)
within a task type definitions. Creates a user variable access name to a pointer, four bytes.
vocabulary multi-tasking ( -- )
Vocabulary containing the multi-tasking extensions to the Forth-83 Standard. These extensions are realized both as primitives and on the forth level.
: mutex ( -- )
Used in the following form:
mutex <semaphore-name> ( -- semaphore)
to create a semaphore for mutual exclusion. Should not be used within other structures as this definition is not a structure definition but a code definition.
: new-task ( -- task)
Used in the following form:
new-task <task-type-name> ( -- task)
to create a new task instance of a task type. Allocates and schedules the task instance.
: receive ( chan -- data)
Receives data from channel. Will wait until sender has performed "send".
: resume ( task -- )
Activates the given task. The task must be a member of the runnable tasks, i.e., scheduled and waiting for activation.
variable running ( -- addr)
Variable containing a pointer to the current running task.
code schedule ( task -- )
Schedules the given task and activates it immediately.
: send ( data chan -- )
Sends data on a channel. Sender will wait until receiver has performed "receive".
: signal ( semaphore -- )
If there is a waiting task on the semaphore this task is resumed else the semaphore counter is incremented.
: struct ( -- )
Creates a named user variable of a structure size. Use in the following form:
struct <struct-type-name> <user-name> ( -- addr)
code task ( users parameters returns code -- task)
Used to create a task instance. The "users" parameter defines the size of the task local variable area in bytes. The "parameters" and "returns" arguments define the size of the tasks parameter and return stack in "cells". Last the "code" parameter is a pointer to forth-level code. Returns a pointer to a task. The task is allocated from the run-time heap and not the dictionary. The "memory" extension word "free" should be used to reclaim the allocated area if needed.
: task.body ( -- )
Used within a task type definition structure to indicate the beginning of the task body part and the end of the user variables.
: task.end ( -- )
Ends a task type definition.
struct.type task.type ( parameters returns -- )
Used in the following form to start the definition of a task type:
<parameters> <returns> task.type <task-type-name>
{ <user-variables> }
task.body
<task-body-definition>
task.end
The two parameters, parameters and returns, define the size in cells of these two areas within a task instance. Local user area is defined by the task field names; "byte", "bytes", "word", "long", "enum", "ptr", and "struct".
code terminate ( -- )
Terminates the current running task and resumes the next task in the runnable task queue.
code user ( offset -- )
Used in the following form to create a local, user, variable within the task instance:
<offset> user <user-name> ( -- addr)
The offset is a relative address from the task pointer.
: wait ( semaphore -- )
Dequeues the task and places it into the semaphore waiting queue if the semaphore counter is zero otherwise the counter is decrements and the task continues. The task status is "WAITING" during the semaphore wait delay.
: who ( -- ) Displays the current queue of runnable tasks.
task.field word ( -- )
Used in the following form:
word <user-name> ( -- addr)
within a task type definitions. Creates a user variable access name to a word, two bytes.
 

INTERNALS

Private definitions in the multi-tasking vocabulary;
struct CHAN +arg ( rendezvous -- addr) private
Structure field within a rendezvous which is the channel for argument passing to the server task.
ptr +body ( task.type -- addr) private
Field access to task type pointer to task body code.
long +count ( semaphore -- addr) private
Field access to semaphore value.
long +data ( chan -- addr) private
Field access to the common data area. Used as holding place for data sent until received.
ptr +ep ( task -- addr) private
Field access of task exception frame pointer.
ptr +fp ( task -- addr) private
Field access of task argument frame pointer.
ptr +ip ( task -- addr) private
Field access of task instruction pointer.
struct CONDITION +not.zero ( semaphore -- addr) private
Field access to semaphore condition for tasks waiting for not zero count.
long +parameters ( task.type -- addr) private
Field access of number of cells for parameter stack of task type.
struct QUEUE +queue ( task -- addr) private
Field access of system queue of task instances.
ptr +r0 ( task -- addr) private
Field access of task return stack bottom pointer.
struct SEMAPHORE +received ( chan -- addr) private
Field access to the received synchronization semaphore.
struct CHAN +res ( rendezvous -- addr) private
Structure field within a rendezvous which is the channel for result passing from the server task to the client task.
long +returns ( task.type -- addr) private
Field access of number of cells for return stack of task type.
ptr +rp ( task -- addr) private
Field access of task return stack pointer.
ptr +s0 ( task -- addr) private
Field access of task bottom of parameter stack pointer.
struct SEMAPHORE +sent ( chan -- addr) private
Field access to the sent synchronization semaphore.
ptr +sp ( task -- addr) private
Field access of task parameter stack pointer.
enum +status ( task -- addr) private
Field access of task status. See "TASK-STATUS-CODES" for possible codes.
long +users ( task.type -- addr) private
Field access of number of bytes for user area of task type.
struct CONDITION +waiting ( condition -- queue) private
Field access to condition queue of waiting tasks.
: make-task ( task.type -- task) private
Creates an anonymous task given a task type instance. Used in the following form:
as <task-type-name> make-task ( -- task)
: task.field ( size -- ) private
Fix size field meta-word. Used to create primary set of field type names, "byte", "word", "long", "ptr", and "enum". Should only be used for definitions internal to "multi-tasking".
 

SEE ALSO

tile(1), forth(3X), enumerates(3X), structures(3X), blocks(3X), queues(3X).  

EXAMPLES

For examples see the test and benchmark library (directory "tst").  

NOTE

The function list is sorted in ASCII order. The type and mode of the entries are indicated together with their parameter stack effect.  

COPYING

Copyright (C) 1990 Mikael R.K. Patel

Permission is granted to make and distribute verbatim copies of this manual provided the copyright notice and this permission notice are preserved on all copies.

Permission is granted to copy and distribute modified versions of this manual under the conditions for verbatim copying, provided also that the section entitled "GNU General Public License" is included exactly as in the original, and provided that the entire resulting derived work is distributed under the terms of a permission notice identical to this one.

Permission is granted to copy and distribute translations of this manual into another language, under the above conditions for modified versions, except that the section entitled "GNU General Public License" may be included in a translation approved by the author instead of in the original English.  

AUTHOR

Mikael R.K. Patel
Computer Aided Design Laboratory (CADLAB)
Department of Computer and Information Science
Linkoping University
S-581 83 LINKOPING
SWEDEN
Email: mip@ida.liu.se

 

Index

NAME
SYNOPSIS
DESCRIPTION
INTERNALS
SEE ALSO
EXAMPLES
NOTE
COPYING
AUTHOR

This document was created by man2html, using the manual pages.
Time: 08:59:41 GMT, January 07, 2023